module.exports=`//@flow
import React, { Component } from "react";
import { connectSize } from "gl-react";
import { Surface } from "gl-react-dom";
import { Blur1D } from "../blurxy";

// empirical strategy to chose a 2d vector for a blur pass
const NORM = Math.sqrt(2) / 2;
export const directionForPass = (p: number, factor: number, total: number) => {
  const f = (factor * 2 * Math.ceil(p / 2)) / total;
  switch (
    (p - 1) %
    4 // alternate horizontal, vertical and 2 diagonals
  ) {
    case 0:
      return [f, 0];
    case 1:
      return [0, f];
    case 2:
      return [f * NORM, f * NORM];
    default:
      return [f * NORM, -f * NORM];
  }
};

// recursively apply Blur1D to make a multi pass Blur component
export const Blur = connectSize(({ children, factor, passes }) => {
  const rec = (pass) =>
    pass <= 0 ? (
      children
    ) : (
      <Blur1D direction={directionForPass(pass, factor, passes)}>
        {rec(pass - 1)}
      </Blur1D>
    );
  return rec(passes);
});

export default class Example extends Component {
  render() {
    const { factor, passes } = this.props;
    return (
      <Surface width={400} height={300}>
        <Blur passes={passes} factor={factor}>
          https://i.imgur.com/iPKTONG.jpg
        </Blur>
      </Surface>
    );
  }
  static defaultProps = {
    factor: 2,
    passes: 4,
  };
}
`
